<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl">
    <script>
        function moveAll(srcClass, targetClass) {
            $('.' + targetClass).append($('.' + srcClass + '> option'));
        }

        function moveSelected(srcClass, targetClass) {
            $('.' + targetClass).append($('.' + srcClass + '> option:selected'));
        }


        $(function () {
            var $roleDiv;
            $('#admin').click(function () {
                //获取选中框到状态,判断是否是勾选状
                var checked = $(this).prop('checked');
                if (checked) {//若是选中是超管,删除角色分配div元素,并存起来
                    $roleDiv = $('#role').detach();
                } else {//若不是选中,恢复角色 div，加到超管 div 元素的后面
                    $('#adminDiv').after($roleDiv);
                }
            });


            //多选下拉框数据提交问题
            $('#submitBtn').click(function () {
                //给右边下拉框中option元素添加选中属性
                $('.selfRoles > option').prop('selected', true);
                //提交表单
                $('#editForm').submit();
                console.log($('#name').val());
            });

            //根据超管复选框选中状态，来决定角色分配div是删除还是显示
            var checked = $('#admin').prop('checked');
            if (checked) {
                // 删除角色的 div
                $roleDiv = $('#role').detach();
            }


            var ids = [];
            //角色去重,右边存在,则左边删除
            $('.selfRoles>option').each(function (i, domEle) {
                ids.push($(domEle).val());
            });

            $('.allRoles>option').each(function (i, domEle) {
                var $option = $(domEle);
                var value = $option.val();
                //jquery的一个方法inArray(ele, array)是判断ele是否在array中存在，
                // 返回值是该元素第一次出现在数组array中的下标，没有时返回-1
                if ($.inArray(value, ids) >= 0) {//存在则删除
                    $option.remove();
                }
            });
            //------------表单验证----------

            $('#editForm').bootstrapValidator({
                feedbackIcons: { //图标
                    valid: 'glyphicon glyphicon-ok',
                    invalid: 'glyphicon glyphicon-remove',
                    validating: 'glyphicon glyphicon-refresh'
                },
                fields: {
                    name: {
                        validators: {//规则
                            notEmpty: { //不能为空
                                message: "用户名不能为空" //错误时的提示信息
                            },
                            stringLength: { //字符串的长度范围
                                min: 1,
                                max: 5
                            },

                            remote: {
                                type: 'post',
                                url: '/employee/checkName.do',//后台检查用户名的方法
                                data: function() {  //自定义提交参数，默认只会提交当前用户名input的参数
                                               return {
                                                   id: $('[name="id"]').val(),
                                                   name: $('[name="name"]').val()
                                               };
                                           },

                                message: '用户名已被注册',
                                delay: 1500
                            }
                        }
                    },
                    password: {
                        validators: {
                            notEmpty: { //不能为空
                                message: "密码必填" //错误时的提示信息
                            },
                        }
                    },
                    repassword: {
                        validators: {
                            notEmpty: { //不能为空
                                message: "密码必填" //错误时的提示信息
                            },
                            identical: {//两个字段的值必须相同
                                field: 'password',
                                message: '两次输入的密码必须相同'
                            },
                        }
                    },
                    email: {
                        validators: {
                            emailAddress: {} //邮箱格式
                        }
                    },
                    age: {
                        validators: {
                            between: { //数字的范围
                                min: 18,
                                max: 60
                            }
                        }
                    }
                }
            }).on('success.form.bv', function () { //表单所有数据验证通过后执行里面的代码
                //提交异步表单
                $("#editForm").ajaxSubmit(function (data) {//回调函数
                    if (data.success) {
                        window.location.href = "/employee/list.do";
                    }
                })
            });

        });


    </script>


</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include  "../common/navbar.ftl">
    <!--菜单回显-->
    <#--    <c:set var="currentMenu" value="employee"/>-->
    <#assign  currentMenu="employee"/>
    <#include  "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id">
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">

                            <input
                                   <#-- <#if employee??>
                                        disabled
                                    </#if>-->
                                    type="text" class="form-control" id="name" name="name"
                                    value="${(employee.name)!}" placeholder="请输入用户名">
                        </div>
                    </div>
                    <#--  <c:if test="${empty employee}">-->
                    <#if !employee??><!--mployee??判断对象是否有值,有就为true-->
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"
                                       placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword"
                                       placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>

                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email"
                                   value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age"
                                   value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#-- <c:forEach items="${depts}" var="department">-->
                                <#list depts as department>
                                    <option value="${department.id}"
                                            <#--${employee.dept.id == department.id ? 'selected' : ''}>-->
                                            <#--方式一-->
                                            <#--<#if employee?? &&employee.dept.id == department.id>
                                                       elected
                                            </#if>-->
                                            <#--方式二-->
                                            ${((employee.dept.id == department.id )? string('selected',''))!}
                                    >${department.name}</option>
                                </#list>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6" style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                            <#--<c:if test="${(employee.admin)!}">-->
                            <#if employee?? && employee.admin>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#--<%--回显所有员工角色--%>-->
                                    <#-- <c:forEach items="${roles}" var="role">-->
                                    <#list roles  as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>

                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#--<c:forEach items="${employee.roles}" var="role">-->
                                    <#list (employee.roles)! as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="button" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include  "../common/footer.ftl">
</div>
</body>
</html>
